草庐IT

Java BufferedImage 内存消耗

全部标签

c++ - Haskell FFI内存分配性能问题

我正在使用FFItoC将中等数量的数据(~100MB)发送到C程序——只是一个字符串列表。但是,我使用的所有方法似乎都花费了不合理的时间(~10秒)。分析后,似乎是实际的内存分配需要时间。我试过:作为常规字符串发送(newCString)转换为ByteStrings(unsafeUseAsCString)转换为字符vector(unsafeWith>>=withForeignPtr...)通过CFFI发送数据的最快方法是什么? 最佳答案 正如ReidBarton在评论中所说,如果您有100MB的字符串,无论您如何处理它,您的分配一开

c++ - 访问冲突读取位置-未终止的字符串(不可读的内存)

我正在使用log4cplus库,但无法使日志记录正常工作。我使用这段代码:PropertyConfigurator::doConfigure(LOG4CPLUS_TEXT("log.properties"));Loggerg_logger=Logger::getInstance(LOG4CPLUS_TEXT("mylogger"));LOG4CPLUS_WARN(g_logger,LOG4CPLUS_TEXT("testtesttest"));它在LOG4CPLUS_WARN处中断并出现错误:访问违规读取位置这是我的调用栈:msvcp110d.dll!std::basic_stream

c++ - 为什么嵌套的initializer_list会导致内存泄漏

最近我将我的项目升级到VisualStudio2013。因此现在可以使用initializer_list功能。我需要在我的单元测试中初始化测试数据。但是我在使用嵌套的initialize_lists时遇到了内存泄漏。#include#includestructTest_Fixture{Test_Fixture():test_data({std::make_shared>(std::vector{0,1}),std::make_shared>(std::vector{2,3,4})}){}std::vector>>test_data;};BOOST_FIXTURE_TEST_CASE(t

c++ - 从内存转储中找出线程消息队列中的消息计数

我知道在任何给定时间通过任何类型的WinAPI调用都无法确定线程队列中有多少消息。我有一个应用程序无法运行,因为PostMessage有时会失败(可能是由于队列增长到10000,尽管我不明白它怎么会增长到这么大)。这是一个间歇性问题,我在它发生的那一刻进行了几次内存转储。显然队列必须在某个地方,本文解释了如何获取它http://moyix.blogspot.com/2008_09_01_archive.htmlEachthreadinWindows(representedbythe_ETHREADstrucutre)hasafieldinitsThreadControlBlock(or

c++ - 在没有段错误的情况下读取程序外部的内存

是否可以在不引发段错误的情况下读取内存地址(真实的,而非虚拟的)?我希望阅读所有事件的、使用过的内存地址和日志结果。 最佳答案 这取决于您使用的操作系统。这应该是可能的,但您需要编写一个内核驱动程序来连接操作系统和硬件,并且此代码必须作为驱动程序运行(假设是Windows,因为用户无法直接与物理内存连接)。 关于c++-在没有段错误的情况下读取程序外部的内存,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.c

c++ - 单一生产者、单一消费者环形缓冲区的最小限制内存排序?

我有一个RingBuffer,它为一个消费者和一个生产者提供服务,并使用两个整数来检测新数据:_lastReadIndex_lastWrittenIndex所以当这两个值不相等时,ringbuffer中有未读数据。当一个项目被添加到环形缓冲区时,生产者递增(和循环缓冲区大小的模数)_lastWrittenIndex。消费者自旋,读取两个值,检查新数据,当有新数据时,它将递增(和模数)_lastReadIndex。三个突出显示的术语强调了关于多线程和内存屏障的要求。考虑到Intel的内存模型,我可以将此设计的内存排序放宽到什么程度?我相信英特尔的内存模型允许加载与早期存储重新排序到不同的

c++ - FMod内存流问题

编辑:嗯...这很有趣。我将设置设置为指针并将其传递。工作得很好。所以,这就解决了。对于任何对答案感到好奇的人,我都会将其打开。我在从内存流在FMod中创建声音时遇到问题。我查看了FMod附带的loadfrommemory示例并遵循了该示例。首先,我正在使用的代码...CSFX::CSFX(CFileData*fileData){FMOD_RESULTresult;FMOD_CREATESOUNDEXINFOsettings;settings.cbsize=sizeof(FMOD_CREATESOUNDEXINFO);settings.length=fileData->getSize(

Elasticsearch-内存结构

ElasticSearch的内存从大的结构可以分堆内存(OnHeap)和堆外内存(OffHeap)。OffHeap部分由Lucene进行管理。OnHeap部分存在可GC部分和不可GC部分,可GC部分通过GC回收垃圾对象,从而释放内存。不可GC部分不能通过GC回收垃圾对象,这部分会通过LRU算法进行对象清除并释放内存。更加具体的内存占用与分配如下图:查看和删除缓存catnodesAPI|ElasticsearchGuide[8.12]|ElasticNodesstatsAPI|ElasticsearchGuide[8.12]|Elastic查看cache情况:GET/_stats/query_c

C/C++内存管理

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录前言1.C/C++内存分布2.C语言中动态内存管理方式:malloc/calloc/realloc/free3.C++内存管理方式 3.1new/delete操作内置类型3.2new和malloc操作符的比较1、用法上,变简洁了2、new可以控制初始化3、自定义类型,开空间+构造函数(初始化)4、new失败了以后抛异常,不需要手动检查3.3 new和delete操作自定义类型4.operatornew与operatordelete函数(重要点进行讲解)4.1operatornew与operatordelete函数(重点)5

c++ - 为最终的 future 自定义内存分配器做准备

我的项目是在c++11中,使用vs2012。现在我觉得不需要使用自定义内存管理,但是我应该采取什么安排以促进最终的future修改?我想过为“new”/“new[]”/“delete”/“delete[]”使用宏,为容器和智能指针使用typedef。什么是最佳实践? 最佳答案 在我看来,您所要做的基本上就是确定您将在整个实现过程中使用的特定约定。让你的架构分配器知道的一个很好的模板是看看这是如何为STL容器实现的,并尝试设计你像它们一样的数据结构。例如,如果您在std::vector上查找示例interface此容器的第二个参数始终